# Chapter 1

## Timebox 1

| 1.0.1 | Outline | for | this | timebox |
|-------|---------|-----|------|---------|
|       |         |     |      |         |

1.0.2 Development Plan

1.0.3 Results

1.0.3.1 Design VHDL for Slave 1 & 2 (Anders)

Requirements to fulfil

Theory

Implementation

verification of requirements

1.0.3.2 Design & implement code for Communicator (Henrik)

Requirements to fulfil

Theory

Implementation

verification of requirements

1.0.3.3 Implementation of the wishbone interface (Jacob)

Requirements to fulfil FR.3.b.i

Theory

**Pin Budget** There is of cause a limited amount of GPIO pins available at the FPGA board, so a detailed pin budget will be made, to clarify how many pins are needed and which function each pin will have. This is essential to design the modules inside the FPGA, or at least to make them work prober without much confusion.



Figure 1.1: Spartan 3A board

Figure 1.1 shows the layout of the Spartan 3A board. The pin connectors J4, J6 and J7 will be used. For the CPU interface, only J4 will be used.

Table 1.1: Data Pins **FPGA FPGA** FUNCTION LPC LPC PIN# PIN PIN# PIN NAME NAME J4 4 C4J2 60 BD0DATA\_PIN0 J4 5 J2 58 BD2DATA\_PIN2 A14 J4 6 J2 56 BD4 DATA\_PIN4 B14 DATA\_PIN6 J4 7 A13 J254BD6 J4 8 D13 J252BD8 DATA\_PIN8 J4 9 **BD10** C13 J250DATA\_PIN10 J4 10 C12 **BD12** DATA\_PIN12 J2 48 J4 11 A12 J2 46 **BD14** DATA\_PIN14 J4 12J259BD1 DATA\_PIN1 D11 J4 13 B12 J2 57 BD3 DATA\_PIN3 J4 14 C11 J255BD5DATA\_PIN5 J4 15 A11 J253BD7DATA\_PIN7 J4 16 D10 J2 51 BD9 DATA\_PIN9 J4 17 DATA\_PIN11 A10 J2 49 **BD11** J4 18**BD13** DATA\_PIN13 E10 $J2\ 47$ J4 19 BD15 DATA\_PIN15 A9 J245

Table 1.1 shows the data pins connections. Referring to FR 3.a.i & FR 3.b.i, 16 pins are reserved for the data transfer.

Table 1.2: Adress Pins FPGA **FUNCTION FPGA** LPC LPC PIN# PIN# PIN PIN NAME NAME J4 20D9J242BA0 ADDR\_PIN0 J4 21 C9 J2 40 BA2 ADDR\_PIN2 J422C8J2 38 BA4 ADDR\_PIN4 J4 23A8 J2 36 BA6 ADDR\_PIN6 J4 24 E7 J2 34 BA8 ADDR\_PIN8 J4 25В8 J241BA1 ADDR\_PIN1 J4 26D8J2 39 BA3 ADDR\_PIN3 J427A7 J2 37 BA5ADDR\_PIN5 J4 28D7ADDR\_PIN7  $J2 \ 35$ BA7  $\overline{\mathrm{C7}}$ ADDR\_PIN9 J4 29 J2 33 BA9

Table 1.2 shows the address pins used. 10 pins are reserved for address.

| Table 1.3: Motor Control Pins |      |          |  |
|-------------------------------|------|----------|--|
| FPGA                          | FPGA | FUNCTION |  |
| PIN #                         | PIN  |          |  |
|                               | NAME |          |  |
| J4 31                         | A6   | M_CTRL4  |  |
| J4 32                         | C5   | M_CTRL3  |  |
| J4 33                         | B6   | M_CTRL2  |  |
| J4 34                         | D4   | M_CTRL1  |  |

Table 1.3 shows the four pins reserved for motor control. 4 output signals to two H-bridges, to control the motors position. One pin for each direction the solar panel has to move; up, down, left right.

Table 1.4: LPC/FPGA Control Pins

| FPGA  | FPGA | LPC   | LPC       | FUNCTION      |
|-------|------|-------|-----------|---------------|
| PIN # | PIN  | PIN#  | PIN       |               |
|       | NAME |       | NAME      |               |
| J4 35 | A5   | J1 45 | 2.14      | Chip Select   |
| J4 36 | B4   | J1 6  | Reset_out | Reset         |
| J4 37 | E13  | J1 35 | BWE       | Write Enable  |
| J4 38 | D3   | J1 36 | BOE       | Output Enable |

Table 1.4 shows the chip select, which has to be high for the FPGA to react on commands from the LPC, Reset for a synchronous reset of both boards. When reset is pressed on the LPC board, Reset\_out will be set low, which the FPGA will react on. Also if the power is lost, the pin will go low, and secure a reset/idle state, until the power is turned on again. Also the Write and Read enable are described, for the LPC to control whether the FPGA has to send or receive data from the LPC.

Table 1.5: LPC Control Pins

| Connection  | LPC   | LPC     | FUNCTION              |
|-------------|-------|---------|-----------------------|
|             | PIN#  | PIN     |                       |
|             |       | NAME    |                       |
| Chip Select | J2 43 | DBUS_EN | Data Bus Enable       |
| Ground      | J2 44 | ABUF_EN | Address Buffer Enable |

Table 1.5 shows that DBUS\_EN is connected to Chip Select. This is enabled when chip select is enabled. This data bus is controlled by the WE and OE signals, and can act both as input and output. This should not be left low, else it will collide with the boards internal data bus, therefore it is connected to Chip Select, and is only low when chip select is enabled. DBUS\_EN is active low.

ABUF\_EN is grounded, to pull it low constantly. This will enable the two buffers for address. Also the control signals are enabled, and act as output.  $^1$ 

| Table 1.6: Others |       |             |
|-------------------|-------|-------------|
| FPGA              | FPGA  | FUNCTION    |
| PIN#              | PIN   |             |
|                   | NAME  |             |
| J4 1              | GND   | GND         |
| J4 2              | +5V   | +5V SUPPLY  |
| J4 3              | +3.3V | +3.3 SUPPLY |
| J4 30             | C6    | FREE        |
| J4 39             | GND   | GND         |
| J4 40             | GND   | GND         |

A lot of text, to describe the table of data!

**State Machine Diagram (Jacob)** Before implementing the VHDL code, a state machine diagram is made to clarify which states the module has to go through. When this is in place, the code is very easy to implement.



Figure 1.2: State Machine Diagram - CpuInterface

<sup>&</sup>lt;sup>1</sup>LPC2478\_OEM\_Board\_Users\_Guide\_Rev\_H, page 10, chap 3.1.6

Figure 1.2 shows the State MAchine Diagram for the CpuInterface. The different states will be discussed in the "implementation" chapter below.

#### Implementation

Important thing first. The module has to check if the reset pin is enabled. If this is the case, it has to reset the board, no matter what. This is why it is set asynchronious. No clock has to be on its rising or falling edge. The reset values is all 0, to be sure no data is stored, no adress is stored and no write/read commands are given to the Wishbone Master.

```
-- Check if reset=high (Unsynchronized)
-- Reset all values to '0'
if(Rst='1') then

Wr_o <= '0';

Rd_o <= '0';

D_o <= (others => '0');

A_o <= (others => '0');

CpuD_o <= (others => '0');
```

If reset is not set, the module has to think syncronous. This is why we check the clock. Both the read and write state is inside the synchronous clock state, and also the chip select (CpuCs\_i) has to be high, in order for the module to respond on read/write commands. When chip select is set high, the adress is sent from the Cpu to the Wishbone Master. The adress can always be set, without any failures occur.

Then it is time to check if the "Read" is set. If it is, then the CPU wants to read data from the FPGA, thats why the data from the Wishbone master (D\_i) is sent to the output to the cpu (CpuD\_o).

Also the Read and Write input from the cpu is sent to the wishbone master. Then the cpu will have to avoid both being high at the same time.

```
elsif(Clk'event and Clk = '1') then --(All sync)
-- Check if active read (CPU read ffrom FPGA)
if(CpuCs_i = '1') then
A_o <= CpuA_i; -- Common for all
if(CpuRd_i = '1') then
Wr_o <= CpuWr_i; -- Enables/Disables master write</pre>
```

```
Rd_o <= CpuRd_i; -- Enables/Disables master read
CpuD_o <= D_i; -- Data from master (D_i) to CPU (CpuD_o)</pre>
```

If read is not high, the write pin has to be checked. If that is enabled, the CpuInterface will send the data received from the Cpu to the Wishbone master. Again both read and write is rooted directly to the Wishbone Master.

```
-- Check if active write (CPU write to FPGA)
elsif(CpuWr_i = '1') then
Wr_o <= CpuWr_i;
Rd_o <= CpuRd_i;
D_o <= CpuD_i; -- Data from CPU (CpuD_i) to Master (D_o)
else</pre>
```

If either read nor write is high, the Cpuinterface will reset the Cpu data out to all "0". Also the read and write are directly rooted to the wishbone master, which also is "0". This will keep the system from making any action when not supposed to.

```
-- Reset values to 0
Wr_o <= CpuWr_i;
Rd_o <= CpuRd_i;
D_o <= CpuD_i;
CpuD_o <= (others => '0');
end if;
```

Last but not least, if chip select is not enabled, all values will be reset, as iff the reset button was pressed. This is to avoid any failures and unwanted actions in the system.

```
-- If Chip not selected (CpuCs_i = '0'), reset all values to '0'.
else
Wr_o <= '0';
Rd_o <= '0';</pre>
```

```
D_o <= (others => '0');
A_o <= (others => '0');
CpuD_o <= (others => '0');
end if;
end if;
end process Cpuinter;
```

verification of requirements

#### 1.0.3.4 Module Design (Jacob)

#### Requirements to fulfil

NR.4.b

#### Theory

The module design shall help us clarify which blocks shall be implemented where. All the hardware, the Spartan 3A board, the LPC2478 and other modules, shall be drawn an connected. This clarifies what the different hardware contains and how they interface with each other. The module design is shown in Figure 1.3



Figure 1.3: Module Design of "system-to-be"

The **solar panel** is physically connected to the two motors, which will turn the panel towards the sun. **The two motors** are each supplied by 12 V DC (Source unknown). Four signals are received from the **FPGA**, that controls which way the motors have to turn. Those signals are sent to two H-bridges, which will invert the voltage, and make the motors turn in different directions. The four signals are controlled by a **PWM** block in the FPGA, to make speed control of the motors possible.

The potentiometers of the motors will return a value to the **ADC** implemented in the FPGA, which then can compare their position, to the position of the sun, received from the LPC2478. The ADC input limit, on the FPGA board is  $3v3^2$ 

The ADC and the PWM are implemented in a wishbone structure, which makes it possible to use it at different platforms, if the wishbone interfaces are obeyed. The two wishbone slaved (PWM, ADC), are interfaced to the LPC2478 through a wishbone master, controlling the communication, and then through a host-controller, onto the FPGA-driver implemented on the LPC2478 board.

The SPARTAN 3A board and the LPC2478 developers kit is a requirement to this project, given by the teachers. The **FPGA** board is software coded hardware, which means it makes most sense to replace some actual hardware by this development board, or maybe make a module more efficient, by replacing some of the software by this "hardware" board. In this case it is replaced by both. The suntracker was meant as pure software, but now a formula, calculating the position of the sun, is implemented as software, and the position of the sun is sent to the FPGA; which compares it to the position of the motors, received by the potentiometers, and then repositioning the motors, according to the sun.

The LPC2478 board is where the software is placed, and are an essential part of the system. This is used for communication, logging and other things, which will be described later. The board is controlled by a small embedded Linux system. Three drivers are implemented, and they are controlled by the kernel, on behalf of three user applications. This board is supplied with a voltage between 9-15V DC<sup>3</sup>.

The first interface was the interface for communication with the FPGA, shortly described above. This is a 16 bit communication line, which is also a requirement for the system. Further there is a chip select, read and write line and finally a supply line, supplying the FPGA with power from the LPC2478 board<sup>4</sup>. The FPGA user application will handle the information that is to be sent and received.

The power generated from the solar panel, will be sent through a **regulator**, which is pure hardware, where the power will be converted from approx 30V, into 30V+/-10%. This output is a common requirement, to make the system function with the other systems.

Two galvanic isolated **sensors** are applied to the input and the output of the regulator, to keep track of how much energy is produced and how efficient the regulator is. Those sensors sends a PWM signal (0-3v)<sup>5</sup> down to the ADC, in the sensor driver, in the LPC2478 board. The user application to the sensor driver will then pack the data and send them to the energy hub, which updates the web-page.

The last user application/driver at the LPC board is the **PLC driver**, which makes the communication to the energy hub possible. This communication is established through UART,

<sup>&</sup>lt;sup>2</sup>FPGA datasheet page 3.

<sup>&</sup>lt;sup>3</sup>LPC2478 print

<sup>&</sup>lt;sup>4</sup>LPC2475 user manual, chap. 5 - External Memory Controller

<sup>&</sup>lt;sup>5</sup>LPC2478 user manual, chap 28.2

which sends and receives messages between the system and the energy-hub. A **PLC module** is implemented too, which is supplied by the powerline and speaks through it too.

### verification of requirements

content...